package s3
import (
awsmiddleware
internalChecksum
s3cust
smithyhttp
)
func ( *Client) ( context.Context, *PutBucketEncryptionInput, ...func(*Options)) (*PutBucketEncryptionOutput, error) {
if == nil {
= &PutBucketEncryptionInput{}
}
, , := .invokeOperation(, "PutBucketEncryption", , , .addOperationPutBucketEncryptionMiddlewares)
if != nil {
return nil,
}
:= .(*PutBucketEncryptionOutput)
.ResultMetadata =
return , nil
}
type PutBucketEncryptionInput struct {
Bucket *string
ServerSideEncryptionConfiguration *types.ServerSideEncryptionConfiguration
ChecksumAlgorithm types.ChecksumAlgorithm
ContentMD5 *string
ExpectedBucketOwner *string
noSmithyDocumentSerde
}
type PutBucketEncryptionOutput struct {
ResultMetadata middleware.Metadata
noSmithyDocumentSerde
}
func ( *Client) ( *middleware.Stack, Options) ( error) {
= .Serialize.Add(&awsRestxml_serializeOpPutBucketEncryption{}, middleware.After)
if != nil {
return
}
= .Deserialize.Add(&awsRestxml_deserializeOpPutBucketEncryption{}, middleware.After)
if != nil {
return
}
if = addSetLoggerMiddleware(, ); != nil {
return
}
if = awsmiddleware.AddClientRequestIDMiddleware(); != nil {
return
}
if = smithyhttp.AddComputeContentLengthMiddleware(); != nil {
return
}
if = addResolveEndpointMiddleware(, ); != nil {
return
}
if = v4.AddComputePayloadSHA256Middleware(); != nil {
return
}
if = addRetryMiddlewares(, ); != nil {
return
}
if = addHTTPSignerV4Middleware(, ); != nil {
return
}
if = awsmiddleware.AddRawResponseToMetadata(); != nil {
return
}
if = awsmiddleware.AddRecordResponseTiming(); != nil {
return
}
if = addClientUserAgent(); != nil {
return
}
if = smithyhttp.AddErrorCloseResponseBodyMiddleware(); != nil {
return
}
if = smithyhttp.AddCloseResponseBodyMiddleware(); != nil {
return
}
if = swapWithCustomHTTPSignerMiddleware(, ); != nil {
return
}
if = addOpPutBucketEncryptionValidationMiddleware(); != nil {
return
}
if = .Initialize.Add(newServiceMetadataMiddleware_opPutBucketEncryption(.Region), middleware.Before); != nil {
return
}
if = addMetadataRetrieverMiddleware(); != nil {
return
}
if = addPutBucketEncryptionInputChecksumMiddlewares(, ); != nil {
return
}
if = addPutBucketEncryptionUpdateEndpoint(, ); != nil {
return
}
if = addResponseErrorMiddleware(); != nil {
return
}
if = v4.AddContentSHA256HeaderMiddleware(); != nil {
return
}
if = disableAcceptEncodingGzip(); != nil {
return
}
if = addRequestResponseLogging(, ); != nil {
return
}
return nil
}
func ( string) *awsmiddleware.RegisterServiceMetadata {
return &awsmiddleware.RegisterServiceMetadata{
Region: ,
ServiceID: ServiceID,
SigningName: "s3",
OperationName: "PutBucketEncryption",
}
}
func ( interface{}) (string, bool) {
:= .(*PutBucketEncryptionInput)
if len(.ChecksumAlgorithm) == 0 {
return "", false
}
return string(.ChecksumAlgorithm), true
}
func ( *middleware.Stack, Options) error {
return internalChecksum.AddInputMiddleware(, internalChecksum.InputMiddlewareOptions{
GetAlgorithm: getPutBucketEncryptionRequestAlgorithmMember,
RequireChecksum: true,
EnableTrailingChecksum: false,
EnableComputeSHA256PayloadHash: true,
EnableDecodedContentLengthHeader: true,
})
}
func ( interface{}) (*string, bool) {
:= .(*PutBucketEncryptionInput)
if .Bucket == nil {
return nil, false
}
return .Bucket, true
}
func ( *middleware.Stack, Options) error {
return s3cust.UpdateEndpoint(, s3cust.UpdateEndpointOptions{
Accessor: s3cust.UpdateEndpointParameterAccessor{
GetBucketFromInput: getPutBucketEncryptionBucketMember,
},
UsePathStyle: .UsePathStyle,
UseAccelerate: .UseAccelerate,
SupportsAccelerate: true,
TargetS3ObjectLambda: false,
EndpointResolver: .EndpointResolver,
EndpointResolverOptions: .EndpointOptions,
UseARNRegion: .UseARNRegion,
DisableMultiRegionAccessPoints: .DisableMultiRegionAccessPoints,
})
}